// pages/meisi/meisi.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    item: {},
    shops: [],
    isLoading: false,
    page: 1,
    pageSize: 10,
    total: 20
  },

  getAllShops(cb) {
    this.isLoading = true
    wx.showLoading({
      title: '数据正在加载中',
    })
    wx.request({
      url: `https://www.escook.cn/categories/${this.data.item.id}/shops`,
      method: 'GET',
      data: {
        _page: this.data.page,
        _limit: this.data.pageSize
      },
      success: (res) => {
        this.setData({
          shops: [...this.data.shops,...res.data]
        })
      },
      complete: () => {
        this.isLoading = false
        wx.hideLoading()
        cb && cb()
      }
    })
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    this.setData({
      item: options
    })
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {
    wx.setNavigationBarTitle({
      title: this.data.item.name,
    })
    this.getAllShops()
  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    if(this.isLoading) {
      return
    } 
    this.setData({
      page: 1,
      pageSize: 10,
      shops: []
    })
    this.getAllShops(() => {
      wx.stopPullDownRefresh()
    })
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    if(this.data.page * this.data.pageSize >= this.data.total) {
      wx.showToast({
        title: '数据已加载完毕',
      })
      return
    }
    if(this.isLoading) {
      return
    } 
    this.setData({
      page: this.data.page + 1  
    })
    this.getAllShops()
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})